package com.person.blog.mapper;

import com.person.blog.pojo.UserEntity;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;


/**
 * 用户信息映射 SQL 操作
 */
@Mapper
public interface UserMapper {
    /**
     * 添加用户
     * @param username 用户名
     * @param password 密码
     * @param registerTime 注册时间
     */
    @Insert("INSERT INTO `user` VALUES (NULL, #{username}, #{password}, #{registerTime})")
    void addUser(@Param("username") String username, @Param("password") String password,
                 @Param("registerTime") Long registerTime);

    /**
     * 通过用户名寻找用户，用于判断该用户名是否已经被注册
     * @param username 用户名
     * @return 用户实体对象
     */
    @Select("SELECT * FROM `user` WHERE `username`=#{username}")
    UserEntity findUserByUsername(@Param("username") String username);

    /**
     * 通过用户名和密码寻找用户，用于用户的登入
     * @param username 用户名
     * @param password 密码
     * @return 用户实体对象
     */
    @Select("SELECT * FROM `user` WHERE `username`=#{username} AND `password`=#{password}")
    UserEntity findUserByUsernameAndPassword(@Param("username") String username, @Param("password") String password);
}